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(S) Test latch circuit 

@ A latch is provided in association with each non- 
volatile memory element used to store configuration 
information on a programmable logic device. In nor- 
mal use. configuration information is written to the 
non-volatile rnemory elements in the usual manner. 
However, during testing configuration information is 
written only to the latches associated with the non- 
volatile memory elements. The latches place the 
data stored therein onto the same architecture bit 
line used by the non-volatile memory elements, al- 
lowing chip configuration testing to be performed 
without actually writing to the non-volatile memory 
elements. The latches can be written to at a much 
faster speed than the non-volatile memory elements 
can be programmed, greatly decreasing the time 
needed for full testing of the programmable logic 
device. 
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© Test latch circuit 

© A latcin is provided in association with eacli non- 
volatile memory element used to store configuration 
information on a programmable logic device. In nor- 
mal use, configuration information is written to the 
non-volatile memory elements in the usual manner. 
However, during testing configuration information is 
written only to the latches associated with the non- 
volatile memory elements. The latches place the 
data stored therein onto the same architecture bit 



line used by the non-volatile memory elements, al- 
lowing chip configuration testing to be performed 
without actually writing to the non-volatile . memory 
elements. The latches can be written to at a much 
faster speed than the non-volatile memory elements 
can be programmed, greatly decreasing the time 
needed for full testing of the prograrnmable logic 
device. 
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TEST LATCH CIRCUIT 



The present invention is related generally to 
integrated circuits, and more specifically to circuits 
included on integrated circuit devices for testing 
purposes. , . - .. 

It is usually desirable to increase the number of 
logical functions performed on a single integrated 
circuit chip. This allows for the replacement of 
severaLintegrated circuit devices by a single de- 
vice, thereby decreasing system cost. Other bene- 
fits also accrue, typically Including lower systern 
power consumption and improved performancei. 

Custom chip design is relatively expensive, 
and design changes are often difficult. Of ihcrea$- 
ing popularity within the electronics industry has 
been the use of Integrated circuit chips which are 
programmable by the-system desigher.or end user. 
These devices are referred to generally as prog- 
rammable logic devices (PLDs). With these de- 
vices, the user can tailor operatipn of a general 
purpose commodity device to this specific needs. 

One common type of PLD includes an AND- 
OR array. This array is programmed to provide 
desired logic functions. Programmable inpiit and 
output buffers are also provided on many such 
devices. A programmable logic device is config- 
ured by writing data into architecture bits, also 
known as configuration bits, on the chip. These bits 
are used to select from various functions which are 
available on the device. 

Configuration bits can be used, for example, to 
define a pin on an integrated circuit chip as an 
output pin or an input pin. An Input or output pin 
can be defined as active high or active low. In 
general, the configuration bits are used to program 
the behavior of the programmable logic device. 
These bits are stored on the chip in non-volatile 
memory. Since the configuration Information is writ- 
ten into non-volatile memory, it can be written to 
the chip by the user, and the chip will retain its 
desired configuration. > . ^ 

The configuration bits allow the programmable 
logic device to be programmed to operate in any of 
several configurations. Chip manufacturers . prefer 
to test all possible configurations to ensure proper 
chip function before shipping the completed de- 
vices to users and resellers. This means that, dur- 
ing testing, the configuration bits must be reprog- 
rammed for each possible configuration. Typically, 
all configuration bits must be cleared prior to. pro- 
gramming a new configuration to be tested. 

The configuration information is typically stored 
in EEPROM. although EPROMs and PROMs are 
also used. With EEPROMs, clear and program 
times are typically on the order of a few millisec- 
onds. This means that, for example. 30-50 ms 



would be needed just to reprogram the configura- 
tion bits on a device having 9 or 10 different 
configurations. 

The delay inherent in programming the con- 
5 figuration bits adds greatly to the total time re- 
quired for chip testing. This adds to tiie overall cost 
of the programmable logic device. If It Is necessary 
to minimize cbst and tester time, it is sometimes 
necessary to test only a few of the possible con- 
10 figurations of each device. 

It would be desirable to provide a mechanism 
which minimized test time while still allowing full 
testability of all device configurations. It is also 
desirable that such a mechanism does not ad- 
75 versely effect normal configuration programming 
and operation of the device. 

It Is therefor an object of the present invention 
to provide a circuit for use with configuration bit 
storage on programmable logic devices which 
20 greatiy decreases the testing time thereof. 

it is a further object of the present invention to 
provide such a circuit which is usable with different 
types of non-volatile memory cells. 

It is another object of the present invention to 
25 provide such a circuit which is simple and requires 
' only a small amount of layout area on an integrated 
circuit chip. 

it is yet anpther object of the present Invention 
to provide such a circuit which does not Interfere 
30 with normal operation and programming of the de- 

vicei 

therefore, according to the present Invention, a 
latch is provided in association with each non- 
volatile memory element used to store configura- 

35 tion information on a programmable logic device. In 
normal use, configuration information is written to 
the non-volatile memory elements in the usual 
manner. However, during testing configuration In- 
formation is written only to the latches associated 

40 with the non-vojatile memory elements. The latches 
place the data "stored tiierein onto the same ar- 
chitecture bit line used by the non-volatile memory 
elements, allpwing chip configuration testing to be 
performed without actually writing to the non-vola- 

45 tile memory elements. The latches can be written 
to at a much faster speed than the non-volatile 
memory elements can be programmed, greatiy de- 
creasing the; time needed for full testing of the 
programmable logic device. 

50 The novel features believed characteristic of 

the Invention are set forth in the appended claims. 
The Invention Itself however, as well as a preferred 
mode of use, and further objects and advantages 
thereof, will best be understood by reference to the 
following detailed description of an Illustrative em- 
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bodiment when read in conjunction with the acconn- 

panying drawings, wherein: 

Rgure 1 is a block diagram illustrating opera- 
tion of a prior art non-volatile nrtemory element 
used for storing configuration information in a 
programmable logic device: 
Figure 2 is a block diagram of a single bit non* 
volatile memory element used for storing con- 
figuration information according to the present 
invention; and 

Figure 3 is a schematic diagram showing de- 
tails of a preferred embodiment of the circuitry 
illustrated In Figure 2. 

Figure 1 illustrates a prior art circuit typically 
used in various kinds of programmable logic de- 
vices. The circuit includes a non-volatile memory 
element 10, which is typically an EEPROM. Otiier 
types of non-volatile memory, such as EPROMs 
and PROMs are also suitable for use with the 
present invention. The memory element 10 is pro- 
grammed in a known manner through tiie use of 
field effect transistor 12. When tiie memory ele- 
ment 10 is programmed, a voltage corresponding 
to a logical 0 or logical 1 is applied to the signal 
BIAS. The signal PROGRAM is raised to turn on 
the. transistor 12 and transfer the value of BIAS Into 
the memory element 10. 

The value stored in the non-volatile memory 
element 10 is available to the remainder of the 
circuitry on the device as the signal ARCH BIT. 
This signal is used by the remainder of the cir- 
cuitry to determine operation of programmable por- 
tions of the device, being used for example, at the 
control inputs of multiplexers. Since the memory 
element 10 is non-volatile, the value stored therein 
remains until it is reprogrammed. 

Many device architectures require that all non- 
volatile memory elements on the chip be first 
cleared, and then programmed. This requires two 
program cycles to complete. Since each memory 
element 10 must be cleared and programmed for 
each different configuration which must be tested, 
the time required for reconfiguring the device is 
quite long. In many instances, the time required to 
configure the device by programming the non- 
volatile memory elements 10 can be 50% or more 
of the total testing time. 

Referring to Figure 2. a circuit for decreasing 
the test time of programmable logic devices is 
shown. A non-volatile memory element 20 is pro- 
grammed by the proper application of signals to 
programming transistor 22 as described in. connec- 
tion with Figure 1. The PR0Gai\1\;*t^^^^^ is used 
to apply tiie value of the BIAS signal to the non- 
volatile memory element 20 by turning on transistor 
22. 

A latch 24 is connected to the non-volatile 
memory element 20. and to a transistor switch 26. 



Transistor 26 Is switched on or off according to the 
value of the sigiiial SET. and connects the value of 
the signal BIAS to the latch 24. 

Latch 24 Is used only during testing of the 

5 programmable logic device. During testing, the val- 
ue stored in the latch 24 provides the signal ARCH 
BIT. During nbrrnal programming and operation of 
the device, the value, stored ia non-volatile memory 
element 20 defines the signal ARCH BIT, and the 

10 latch 24 has no effect. 

Latch 24 is a volatile device, and data can be 
stored thereon at much faster speeds than is possi- 
ble for the memory element 20. Using current 
technology, data may be written to latch 24 in 

IS approximately 10-20 nanoseconds, while memory 
element 20 typically requires a write time of 1-2 
milliseconds. This reduces the overall testing time 
of the device dramatically, while still providing 
complete testing of all possible configurations. 

20 The latch 24 may be designed in any of a 

number of different ways, and a preferred embodi- 
ment is shown in Figure 3. The non-volatile mem- 
ory element 20 contains a non-volatile memory cell 
30 as known in the art. Memory element 20 in- 

25 eludes an output stage containing an inverter 32 
and a pull-up transistor 34. Transistor 34 Is prefer- 
ably a depletion; mode device connected as shown 
In order to provide a resistive load. The output of 
inverter 32 provides the signal ARCH BIT. 

30 The addition of feedback transistor 36 to the 

output stage of memory element 20 forms the latch 
24. The gate of transistor 36 is connected to the 
output of the inverter 32, and transistor 36 acts as 
a switch between node 38 and ground. Program- 

35 ming transistor 26 is also connected to node 38. 
and couples the voltage of BIAS thereto when tiie 
signal SET is high. 

During testing, if BIAS is 0 volts and set is 
high, node 38 is at ground potential. This causes 

40 the output of inverter 32 to be high, turning on 
transistor 36 and connecting node 38 to ground 
through transistor 36. Even after transistor 26 is 
turned off. node 38 is held at ground potential 
through transistor 36. 

45 If BIAS Is at a high voltage during testing, and 

set is high, node 38 is also high. This drives the 
output of inverter 32 to ground potential, turning off 
transistor 36. When transistor 26 is turned off after 
the test cycle is completed, node 38 will remain at 

60 voltage Vcc (high). Thus, it is seen that the BIAS 
voltage applied .to node 38 remains stored in the 
latch defined by transistors 34, 36. and inverter 32." 

V/hBn testing the prdgrainmaBle logic device, 
the non-volatile memory cell 30 should be set to a 

55 state which does not affect the voltage on node 38. 
Memory cell 30 Is programmed off. which Is re- 
fected as a logical 0 on ARCH BIT. if the voltage 
on, node 38 is driven low by the signal BIAS during 
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test programming, it will stay low as described 
above because transistor 36 will be ON. 

During normal operation, the voltage on node 
38 is determined by the value stored in non-volatile 
memory cell 30. This value Is inverted in inverter s 
32 and available as the signal ARCH BIT. Since 
transistor 36. in concert with load transistor 34. acts 
as an inverter, transistor 36 has no effect on the 
normal operation of memory cell 20. 

The embodiment described in Figure 3 adds to 
only two transistors to the circuitry normally re- 
quired. These are the feedback transistor 36 and 
the test programming transistor 26. This small 
space penalty allows extremely fast testing of the 
programmable logic device, which greatly reduces is 
testing time. The latch 24 may be implemented 
using other circuitry, as will become apparent to 
those skilled in the art. The design of the latch 24 
will be, in part, dictated by the design of the non- 
volatile memory cell 30. The only requirement for 20 
such latch 24 is that its value detenmines the value 
of ARCH BIT during testing, and that it has no . 
effect on normal operation of the device. 

While the invention has been particularly 
shown and described with reference to a preferred 25 
embodiment, It will be understood by those skilled 
in the art that various changes in form and detail 
may be nriade therein without departing from the 
spirit and scope of the invention. 



Claims 

1. A test circuit for use in an integrated circuit 
device, comprising: 35 
an output signal line coupled to said non-volatile 
memory element; 

a latch coupled to said output signal line; and 
means for setting a value for said latch during 
testing, wherein a value of said outut signal line is 40 
determined by the latch value during testing, and 
Avherein the output signal line value is determined 
by a value of said non-volatile memory element 
except during testing. 

2. The device of Claim 1. wherein said latch value 4S 
setting means comprises a transistor switch con- 
nected to said latch and to a programmed bit 
value, said switch being controlled by a test pro- 
gramming signal. 

3. The device of Claim 2. wherein the programmed so 
bit value Is also coupled to said non-volatile mem- 
ory element, wherein said non-volatile device is 
programmed during a normal programming by the 
programmed bit value. - 

4. The device of Claim 3, wherein the programmed 55 
bit value Is coupled to said non-volatile memory 
element through a second transistor switch, said 
second switch being controlled by a normal pro- 



gramming signal. 

5. The device of Claim 1 , wherein said non-volatile 
memory element comprises: 

a memory storage cell; and 
an output stage having an inverter and a pullup 
load element at an input to the Inverter, wherein an 
output of the inverter is connected to the output 
signal line. 

6. The device of Claim 5. wherein said latch com- 
prises: 

a transistor switch connected between the inverter 
input and ground, and having a control input con- 
nected to the inverter output. 

7. A method for programming a configuration bit 
during testing of an integrated circuit, comprising 
the steps of: 

providing a non-volatile memory element and a 
latch connected to a configuration bit signal line; 
during testing, setting a value In the latch to control 
a value of the configuration bit signal line; and 
otherwise, controlling the value of the configuration 
bit signal line by a value stored in the non-volatile 
memory element. 
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